import {
  baseRecUrl
} from './request/api'

App({
  onShareAppMessage() {
    wx.onAppRoute(() => {
      const pages = getCurrentPages() //获取加载的页面
      const view = pages[pages.length - 1] //获取当前页面的对象
      if (!view) return false //如果不存在页面对象 则返回
      // 若想给个别页面做特殊处理 可以给特殊页面加isOverShare为true 就不会重写了
      const data = view.data
      if (!data.isOverShare) {
        data.isOverShare = true
        const notOverRoute = ['pages/my-group/my-group', 'pages/index/pages/share/share']
        if (notOverRoute.indexOf(view.route) === -1) {
          wx.showShareMenu({
            withShareTicket: true,
            menus: ['shareAppMessage', 'shareTimeline']
          })

          view.onShareAppMessage = async (res) => { //重写分享配置
            const userInfo = wx.getStorageSync('userInfo')
            if (userInfo) {
              let shareTitle = null;
              let shareImage = baseRecUrl + '/imgs/share-img.png';
              const path = "/pages/index/index?id=" + authInfo.id
              return {
                title: shareTitle,
                imageUrl: shareImage,
                path: path
              }
            } else {
              wx.showToast({
                icon: 'error',
                title: '请登录后分享'
              })
            }
          }
        }
      }
    })
  },
  onLaunch() {
    this.autoUpdate()
    // if (wx.getStorageSync('userInfo')) {
    //   wx.login({
    //     success: (res0) => {
    //       myGet(refreshSession, {
    //         code: res0.code
    //       }, (res) => {
    //         wx.setStorageSync('loginCode', res0.code)
    //       })
    //     }
    //   })
    // }
    //重新登录
    this.onShareAppMessage()
    // 获取手机系统信息
    wx.getSystemInfo({
      success: res => {
        const screenHeight = res.screenHeight
        //导航高度
        this.globalData.screenHeight = screenHeight
        this.globalData.statusBarHeight = res.statusBarHeight;
      },
      fail(err) {
        console.log(err);
      }
    })
  },
  globalData: {
    code: '',
    scrollHeight: 744,
    screenHeight: 744,
    statusBarHeight: 20
  },
  autoUpdate: function () {
    var self = this
    // 获取小程序更新机制兼容
    if (wx.canIUse('getUpdateManager')) {
      const updateManager = wx.getUpdateManager()
      //1. 检查小程序是否有新版本发布
      updateManager.onCheckForUpdate(function (res) {
        // 请求完新版本信息的回调
        if (res.hasUpdate) {
          //检测到新版本，需要更新，给出提示
          wx.showModal({
            title: '更新提示',
            content: '检测到新版本，是否下载新版本并重启小程序？',
            success: function (res) {
              if (res.confirm) {
                //2. 用户确定下载更新小程序，小程序下载及更新静默进行
                self.downLoadAndUpdate(updateManager)
              } else if (res.cancel) {
                //用户点击取消按钮的处理，如果需要强制更新，则给出二次弹窗，如果不需要，则这里的代码都可以删掉了
                wx.showModal({
                  title: '温馨提示~',
                  content: '本次版本更新涉及到新的功能添加，旧版本无法正常访问的哦~',
                  showCancel: false, //隐藏取消按钮
                  confirmText: "确定更新", //只保留确定更新按钮
                  success: function (res) {
                    if (res.confirm) {
                      //下载新版本，并重新应用
                      self.downLoadAndUpdate(updateManager)
                    }
                  }
                })
              }
            }
          })
        }
      })
    } else {
      // 如果希望用户在最新版本的客户端上体验您的小程序，可以这样子提示
      wx.showModal({
        title: '提示',
        content: '当前微信版本过低，无法使用该功能，请升级到最新微信版本后重试。'
      })
    }
  },
  /**
   * 下载小程序新版本并重启应用
   */
  downLoadAndUpdate: function (updateManager) {
    var self = this
    wx.showLoading();
    //静默下载更新小程序新版本
    updateManager.onUpdateReady(function () {
      wx.hideLoading()
      //新的版本已经下载好，调用 applyUpdate 应用新版本并重启
      updateManager.applyUpdate()
    })
    updateManager.onUpdateFailed(function () {
      // 新的版本下载失败
      wx.showModal({
        title: '已经有新版本了哟~',
        content: '新版本已经上线啦~，请您删除当前小程序，重新搜索打开哟~',
      })
    })
  }
})